草庐IT

java - JBPM6服务任务执行java代码

全部标签

ruby - Sinatra 服务器推送?

将数据从用Sinatra编写的服务器推送到客户端的最佳方法是什么?类似于聊天室,但没有每2500毫秒进行一次Ajax轮询。我知道Rails中的Juggernaut,但对Sinatra很好奇。 最佳答案 谷歌搜索了一下thisblogpostbyMarc-AndréCournoyer,其中讨论了瘦Web服务器的异步响应功能,并包含一个指向async-sinatra库的链接来执行此操作。你也可以看看orbited-ruby,Orbited的Ruby实现cometd服务器。这两个看起来都非常新且未经测试,因此您可能需要自己进行一些修改才能

ruby-on-rails - 在 Rails 3 生成器中多次调用任务

我正在编写一个Rails3生成器来创建两个不同的模型。这是我正在尝试做的一个非常简单的例子:defmy_generator_taskinvoke"model",["foo"]invoke"model",["bar"]end问题是Thorinvokemethod只调用一次任务,因此对“模型”任务的第二次调用永远不会发生,并且永远不会创建“bar”模型。有谁知道一种优雅的方式来实现这一目标,最好是以一种不会破坏使用生成器运行“railsdestroy”的能力的方式? 最佳答案 再想一想,这样也可以在不迁移的情况下运行多个模型生成器Rai

ruby - Thor 可执行文件 - 忽略任务名称

雷神维基页面,MakinganExectable,向您展示了如何创建一个看起来像这样的thor支持的CLI命令:庆典./mythorcommandfoo这需要您将thor任务foo作为第一个参数传递。我还可以使用thor的default_method运行不带任何参数的thor可执行文件:庆典./神话命令但是,我想传入一个可变字符串作为第一个参数:庆典./mythorcommand"somevalue"这不起作用,因为thor命令期望第一个参数是任务名称。有没有办法忽略任务名称并将第一个参数发送到默认方法?如果这个功能不存在,我认为添加一个将所有命令行参数传递到一个任务/方法中的方法会非

ruby - 你如何在 Capistrano 中为不同的角色定义不同的相同任务?

我正在使用Capistrano来处理我的部署,我在我的设置中有两个不同的角色-:web和:processing。它们都有通常的:deploy任务,但:restart任务对于两种类型的服务器需要不同。所以我的第一次尝试是这样的:task:restart,:roles=>:webdorun"...webrelatedrestartstuff..."endtask:restart,:roles=>:processingdorun"...processingrelatedrestartstuff..."end这不起作用,因为第二个:restart(对于:processing角色)替换了第一个:

ruby-on-rails - 如何测试 Rails ERB 模板的代码覆盖率?

我只是为旧版Rails应用程序构建测试套件。simplecovgem非常适合查找需要测试覆盖的应用程序的暗角(或者可能完全未使用但可以删除的暗角)。我通过在test/test_helper.rb的顶部包含以下内容来调用simplecov:require'simplecov'SimpleCov.start('rails')问题是这不会检查模板中嵌入的所有代码。那里有各种各样的垃圾,我敢肯定其中很多都可以删除,但如果代码覆盖工具可以将我指向未使用的位,那就太好了。对Ruby1.9的Coverage库进行的一些实验让我相信,只有将模板以某种方式预编译为Ruby代码,保存在Ruby源文件中,然

ruby - 如何检查 ruby​​ 代码中的 ruby​​ 语法错误

我现在使用以下来检查语法错误:system"ruby-wcpath/to/file.rb"但是如果文件太多会很浪费时间(比如重构代码),所以我的问题是有没有办法在ruby代码中进行ruby语法检查? 最佳答案 在MRI下,你可以使用RubyVM::InstructionSequence#compile(relevantdocumentation)编译Ruby代码(如果有错误会抛出异常):2.1.0:001>RubyVM::InstructionSequence.compile"a=1+2"=>@>2.1.0:002>RubyVM::

ruby - 我可以覆盖任务 :environment in test_helper. rb 来测试 rake 任务吗?

我在Rakefile中有一系列rake任务,我想将其作为我的规范等的一部分进行测试。每个任务都以以下形式定义:task:do_somthing=>:environmentdo#Dosomethingwiththedatabasehereend:environment任务设置ActiveRecord/DataMapper数据库连接和类。我没有将其用作Rails的一部分,但我有一系列测试,我喜欢将其作为BDD的一部分运行。此片段说明了我如何尝试测试rake任务。defsetup@rake=Rake::Application.newRake.application=@rakeloadFile

ruby-on-rails - 如何让 Rake 任务在我的 Sinantra 应用程序/环境下运行?

我正在使用Sinatra,我想设置Rails具有的一些方便的rake任务,特别是rakedb:seed。我的第一遍是这样的:namespace:dbdodesc'Loadtheseeddatafromdb/seeds.rb'task:seeddoseed_file=File.join(File.dirname(__FILE__),'db','seeds.rb')system("rackshracksh是一个模仿Rails控制台的gem。所以我只是将种子文件中的代码直接输入其中。它有效,但显然并不理想。我想做的是创建一个环境任务,允许命令在Sinanta应用程序/环境下运行,如下所示:t

ruby - ruby代码是如何执行的

我最近开始学习Ruby。我知道Ruby是一种解释型语言(尽管“每种”语言都是因为它被CPU解释为机器代码)。但是ruby​​解释器如何将用Ruby编写的代码转换为机器码呢?我读过解释器不读取源代码,而是字节码,但是我永远不必像在Java中那样进行编译。那么,这是Ruby为您做的另一件事吗?如果是,它会在运行时生成字节码吗?因为您永远不会像在Java中那样获得.class文件。最重要的是,我阅读了关于即时编译器的所有内容,这些编译器显然对字节代码做了一些事情,因此它运行得更快。如果是上述情况,解释器是否首先扫描所有源代码,将其转换为字节码,然后在运行时使用JIT再次编译?最后,我不是在寻

ruby-on-rails - 使用 Capistrano 部署 - 仅针对匹配的服务器运行

我尝试使用Capistrano部署我的应用程序,但我收到此错误消息:`deploy:setup'isonlyrunforserversmatching{:except=>{:no_release=>true}},butnoserversmatched运行此命令时:bundleexeccapdeploy:setup这是我的deploy.rb文件。set:application,"example.com"set:repository,"git@github.com:username/repo.git"set:use_sudo,falseset:scm,:gitset:web,applica